<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "https://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Language" content="zh-CN"><link href="stylesheet.css" media="all" rel="stylesheet" type="text/css">
<title>用户定义函数</title>
<script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
</head><body class="SECT1">
<div>
<table summary="Header navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><th colspan="5" align="center" valign="bottom">PostgreSQL 8.2.3 中文文档</th></tr>
<tr><td width="10%" align="left" valign="top"><a href="extend-type-system.html" accesskey="P">后退</a></td><td width="10%" align="left" valign="top"><a href="extend.html">快退</a></td><td width="60%" align="center" valign="bottom">章33. 扩展 SQL</td><td width="10%" align="right" valign="top"><a href="extend.html">快进</a></td><td width="10%" align="right" valign="top"><a href="xfunc-sql.html" accesskey="N">前进</a></td></tr>
</table>
<hr align="LEFT" width="100%"></div>
<div class="SECT1"><h1 class="SECT1"><a name="XFUNC">33.3. 用户定义函数</a></h1><a name="AEN36236"></a>
<p> PostgreSQL 提供四种类型的函数：</p>
<ul>
<li><p>查询语言函数(用 SQL 写的函数)(<a href="xfunc-sql.html">节33.4</a>)</p></li>
<li><p>过程语言函数(用诸如 PL/pgSQL 或 PL/Tcl 语言写的函数)(<a href="xfunc-pl.html">节33.7</a>)</p></li>
<li><p>内部函数(<a href="xfunc-internal.html">节33.8</a>)</p></li>
<li><p>C 语言函数(<a href="xfunc-c.html">节33.9</a>)</p></li>
</ul>
<p>每种函数都可以用一个基本类型、复合类型、或是两者的组合作为参数。另外，每种函数都可以返回一个基本类型或复合类型的值。函数也可以定义为返回基本类型或复合类型的集合。</p>
<p>许多类型的函数可以接受或者返回某种类型的伪类型(比如多态类型)，但是可用的东西是变化的。参考每种类型的函数的描述获取更多细节。</p>
<p>定义 SQL 函数更容易些，所以我们将从这里开始。大多数用于 SQL 函数的概念将和其它类型的函数一致。</p>
<p>综观全章，如果你先阅读一下 <a href="sql-createfunction.html"><i>CREATE FUNCTION</i></a> 的手册页应该会对理解本章的例子很有帮助。本章的例子还可以在 PostgreSQL 源代码发布的 <tt class="FILENAME">src/tutorial</tt> 目录里的 <tt class="FILENAME">funcs.sql</tt> 和 <tt class="FILENAME">funcs.c</tt> 文件中找到。</p>
</div>
<div>
<hr align="LEFT" width="100%">
<table summary="Footer navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><td width="33%" align="left" valign="top"><a href="extend-type-system.html" accesskey="P">后退</a></td><td width="34%" align="center" valign="top"><a href="index.html" accesskey="H">首页</a></td><td width="33%" align="right" valign="top"><a href="xfunc-sql.html" accesskey="N">前进</a></td></tr>
<tr><td width="33%" align="left" valign="top">PostgreSQL 类型系统</td><td width="34%" align="center" valign="top"><a href="extend.html" accesskey="U">上一级</a></td><td width="33%" align="right" valign="top">查询语言(SQL)函数</td></tr>
</table>
</div>
</body></html>